home *** CD-ROM | disk | FTP | other *** search
/ MACD 5 / MACD 5.bin / workbench / time / clock1_2 / clock.doc < prev    next >
Encoding:
Text File  |  1994-05-16  |  12.7 KB  |  342 lines

  1. clock 1.2 - A flexible, efficient digital clock with date and memory watching
  2.  
  3. Copyright © 1994 by Peter Schachte
  4.  
  5. This is an efficient digital titlebar clock that can also show date,
  6. day of week, free chip/fast/total memory, largest free
  7. chip/fast/either memory block, with full control over formatting, pen
  8. color for various parts of the display, and refresh frequency.  The
  9. clock can also show the local time in a different time zone.  Clock
  10. only updates parts of the display that need updating, so CPU usage is
  11. kept very low.  This program should work under AmigaOS 1.2 and up.
  12.  
  13.  
  14.  
  15. DISCLAIMER
  16.  
  17. I hereby disclaim all responsibility for any damages caused by this
  18. program.  Use it at your own risk.  It's hard to see what damage could
  19. be be caused by a clock program, but if any is, don't sue me.
  20.  
  21.  
  22.  
  23. DISTRIBUTION
  24.  
  25. This code is based on Mike Meyer's clock program, though by now very
  26. little of his code remains.  In fact, I've changed the spirit of his
  27. program, which was quite small and simple; now it's (relatively) large
  28. and complex, and probably has altogether too many features.
  29.  
  30. Nevertheless, here's Mike's original copyright notice:
  31.  
  32. ================================================================
  33. clock - a dumb, digital clock in the upper right-hand corner. Designed
  34.     to be small, not flexible!
  35.  
  36. Copyright (c) 1986, Mike Meyer
  37.  
  38. Permission is hereby granted to distribute this program for any purposes
  39. whatsoever, so long as this notice, including the above copyright, is
  40. included with the distribution. Unlike other people, I don't care if you
  41. make money off of this, so long as I get credit for having written it.
  42. ================================================================
  43.  
  44. I likewise hereby grant the right to distribute this program for
  45. any purposes whatsoever, as long as this notice, including my
  46. copyright and Mike's, is included with the distribution.
  47.  
  48.  
  49.  
  50. WHY ANOTHER CLOCK
  51.  
  52. I know, I know, there are many good clock programs available, why
  53. would I write another one?
  54.  
  55. I had been using a slightly modified version of Mike Meyer's clock
  56. program since AmigaOS 1.2, and hadn't though much about it, when I
  57. found a copy of Stefan Sticht's public domain Uhr clock on Aminet.  I
  58. really liked the look of and flexibility of it, and promptly replaced
  59. my old clock with it.  But after a week or so I realized that there
  60. seemed to be some interaction between Uhr and Martin Korndörfer's
  61. Magic Menu package, which caused the machine to lock up for about 30
  62. seconds occasionally when a menu was popped up.  Without Uhr running,
  63. this doesn't seem to happen.  I couldn't part with Magic Menus, so I
  64. went back to Mike Meyer's clock.
  65.  
  66. But by then I was dissatisfied with the boring Topaz font and fixed
  67. display, so I dusted off Mike's clock sources and set to work.  Now,
  68. having put far too many features into this simple program, I'm
  69. releasing it upon the world.  Here are some of the features of this
  70. clock program:
  71.  
  72.     o It's pretty efficient, only updating parts of the window
  73.       that have changed since the last display, and only actually
  74.       pulling the window to the front when it finds itself
  75.       covered.  Clock's default display, uses about a third to a
  76.       tenth of the machine cycles of Uhr's default display,
  77.       according to xoper.  This despite the fact that clock runs
  78.       at higher priority, keeps itself in front, and shows free
  79.       memory statistics, none of which Uhr does by default.
  80.  
  81.     o It works under OS >=1.2 (though I've only tested it under
  82.       1.3 and 2.1).
  83.  
  84.     o It shows available memory and largest available memory
  85.       block, for fast memory, chip memory, or both, in bytes or
  86.       kilobytes.
  87.  
  88.     o It allows you to organize the clock display into fixed
  89.       segments separated by vertical bars (or nice 3D-look bars
  90.       under OS 2.0 or better).  Each segment will be allocated the
  91.       space it would occupy at its widest, and will be centered in
  92.       that space.  This only matters much for weekday and month
  93.       names.  This makes it easier to find the information of
  94.       interest at a glance.
  95.  
  96. By the way, none of this should be construed as a criticism of Uhr.
  97. As I said, I really liked Uhr, there were just a few things about it
  98. that didn't suit me.  And I did consult Uhr's sources to help be get
  99. the event loop for this program right.
  100.  
  101. In fact, Uhr is better than this clock program in the following ways:
  102.  
  103.     o Clock doesn't support internationalization.  Sorry, you're
  104.       stuck with english month and day names.  I'd like to make it
  105.       use locale.library if it's there, but I don't have the
  106.       includes (I expected to find them in my SAS/C 6.3 package,
  107.       but no such luck).  I may fix this if I get ahold of the
  108.       includes.
  109.  
  110.     o Clock is three or four times bigger than Uhr.  This is
  111.       because of the code to handle incremental redisplay, and
  112.       because, in order to make it work under pre 2.0 systems,
  113.       I have to include code for things that are in more recent
  114.       libraries.
  115.  
  116. So the inspiration for this program comes from Stefan Sticht's Uhr,
  117. and the base for the software was Mike Meyer's original Clock program.
  118. Thanks to both of them.
  119.  
  120.  
  121.  
  122. INSTALLATION
  123.  
  124. Under AmigaOS 2.0 and better, the easiest thing is to drag the clock
  125. icon to your sys:wbstartup drawer.  Under 1.3 and older, you'll need
  126. to drag the clock to some appropriate place, and put a line in your
  127. s:startup-sequence or s:startupII file to launch the clock.  In this
  128. case you might prefer to use the program clock-det, which detaches
  129. itself, so you don't need to run or runback it.  clock-det is
  130. identical to clock, except for detaching itself, and being about 1K
  131. bigger.
  132.  
  133.  
  134.  
  135. CUSTOMIZATION
  136.  
  137. You can customize clock and clock-det (hereafter, where I write clock,
  138. I mean either program) by passing parameters on the command line, or
  139. by setting up tooltypes on the icon.  If you launch clock from the CLI
  140. or startup script, the tooltypes will be ignored, so you'll have to
  141. use command line parameters.
  142.  
  143. On the command line, parameters are specified by alternating parameter
  144. names and values, like
  145.  
  146.     clock PARAM1 VALUE1 PARAM2 VALUE2 ...
  147.  
  148. In tooltypes, of course, they are specified as
  149.  
  150.     PARAM1=VALUE1
  151.     PARAM2=VALUE2
  152.  
  153. Either way, the parameters and possible values are the same.
  154.  
  155. The parameters you can specify are:
  156.  
  157. INTERVAL    The time between updates of the clock window, in
  158.         tenths of a second.  Defaults to 10, updating every
  159.         second.  Note that the window is only brought to the
  160.         front every INTERVAL tenths of a second, so making
  161.         this too long will allow your window to be buried for
  162.         that long.
  163.  
  164. PRIORITY    The priority of the clock process.  Defaults to 1,
  165.         which is just a bit higher than most other things.
  166.         Having a priority greater than 0 makes displaying
  167.         memory statistics more useful, as they get updated
  168.         even while a CPU hog process is running (assuming it
  169.         runs at priority 0 or less).
  170.  
  171. LEFT        The horizontal position of the clock window.  If the
  172.         number is positive, this is the X coordinate of the
  173.         left edge of the window.  If it is negative, it is the
  174.         pixel offset between the right of the screen and the
  175.         right side of the clock window.  Defaults to the right
  176.         amount of space so that the window lies just to the
  177.         left of the depth/zoom gadgets of a window flush with
  178.         the right side of the screen.  For >=2.0, this means the
  179.         default is -46; for <=1.3, its -52.
  180.  
  181. TOP        The vertical position of the window.  Again, negative
  182.         numbers are measured between the bottom of the window
  183.         and the bottom of the screen, while positive numbers
  184.         are offsets from the top of the screen.  Default is 0.
  185.  
  186. BACKGROUND    The pen color to use as the background color of the
  187.         clock.  Defaults to 0, which is the usual window and
  188.         screen background color.  If you use Martin
  189.         Huttenloher's beautiful Magic WB colors, color 6 looks
  190.         quite nice.
  191.  
  192. PADDING        The number of pixels to leave empty at the left and
  193.         right sides of the clock.  This amount of space is
  194.         also left on either side of a bar (see %| format
  195.         below).  Defaults to 5.
  196.  
  197. OFFSET        A number of minutes to add to the current local time
  198.         to give the time to show in the clock.  If you want to
  199.         put up a clock showing the current time in Paris or
  200.         Rome, use this offset.  Note that the offset is in
  201.         minutes, and may be positive or negative.  The
  202.         default, of course, is 0.
  203.  
  204. FORMAT        A format string specifying exactly what to show in the
  205.         clock window.  Format specifiers are introduced by a
  206.         '%' character.  All other characters are shown in the
  207.         clock as is, much like a printf() format string.  Note
  208.         that '\' is not a special character in the format
  209.         string.  The definition of the format string is much
  210.         the same as that use by Uhr, but extended with a few
  211.         new features.  Here's the full set:
  212.  
  213.         TIME
  214.  
  215.             %H  hour in 24 hour time, zero-filled
  216.             %q  hour in 24 hour time whitespace-filled
  217.             %I  hour in 12 hour time, zero-filled
  218.             %Q  hour in 12 hour time whitespace-filled
  219.             %M  minute
  220.             %S  second
  221.             %p  "AM" or "PM"
  222.             %r  same as "%I:%M:%S %p"
  223.             %R  same as "%H:%M"
  224.             %T  same as "%H:%M:%S"
  225.             %X  same as "%H:%M:%S"
  226.         
  227.         DATE
  228.  
  229.             %y  last two digits of the year, zero filled
  230.             %Y  the full four-digit year
  231.             %b  short version of the month name
  232.             %h  same as %b
  233.             %B  full month name
  234.             %m  month number, zero filled.
  235.             %J  month number, whitespace filled.
  236.             %d  day of the month, zero filled.
  237.             %e  day of the month, whitespace filled.
  238.             %a  short version of the day of the week
  239.             %A  full day of the week
  240.             %w  day of the week, as a digit 1-7
  241.             %j  day of the year, as a number 1-366
  242.             %U  week number, 1-53, with Sunday beginning the week
  243.             %W  week number, 1-53, with Monday beginning the week
  244.             %D  same as "%m/%d/%y"
  245.             %x  same as "%m/%d/%y"
  246.             %c  same as "%a %b %d %H:%M:%S %Y"
  247.             %C  same as "%a %b %e %T %Z %Y"
  248.  
  249.         MEMORY
  250.  
  251.             %f  bytes of free FAST memory
  252.             %F  kilobytes of free FAST memory
  253.             %g  bytes of free CHIP memory
  254.             %G  kilobytes of free CHIP memory
  255.             %K  total bytes of free memory
  256.             %k  total kilobytes of free memory
  257.             %o  size of largest block of CHIP memory, in bytes
  258.             %O  size of largest block of CHIP memory, in kilobytes
  259.             %v  size of largest block of FAST memory, in bytes
  260.             %V  size of largest block of FAST memory, in kilobytes
  261.             %z  size of largest block of memory, in bytes
  262.             %Z  size of largest block of memory, in kilobytes
  263.  
  264.         FORMATTING
  265.  
  266.             %0  Choose pen 0 for following text
  267.             %1  Choose pen 1 for following text
  268.             %2  Choose pen 2 for following text
  269.             %3  Choose pen 3 for following text
  270.             %4  Choose pen 4 for following text
  271.             %5  Choose pen 5 for following text
  272.             %6  Choose pen 6 for following text
  273.             %7  Choose pen 7 for following text
  274.             %8  Choose pen 8 for following text
  275.             %9  Choose pen 9 for following text
  276.             %|  A top-to-bottom bar separating parts of clock
  277.             %%  A percent sign character
  278.             %n  newline (ignored since clock is only 1 line)
  279.             %t  tab (ignored for now)
  280.         
  281.         The default format is
  282.  
  283.             "%2Chip: %1%G%|%2Fast: %1%F%|%e %b %y%|%A%|%q:%M"
  284.  
  285.  
  286.  
  287.  
  288. SOURCE CODE
  289.  
  290. I've included the source code and a makefile for use with SAS/C v6.
  291. If you make an interesting improvements to this clock, or if you fix
  292. any bugs, please send me a copy.  If I like it I'll include it in the
  293. next release.
  294.  
  295.  
  296.  
  297. BUGS AND POTENTIAL IMPROVEMENTS
  298.  
  299. There's one bug I know about.  When you close the active window, and
  300. this makes the clock window the active window, the display is
  301. sometimes corrupted.  I don't know why I don't seem to get an
  302. IDCMP_ACTIVEWINDOW message in this case, but since the clock isn't
  303. notified, it isn't refreshed.  To get it refreshed, all you have to do
  304. is click anywhere, either in another window, or in the screen
  305. background, or in the clock window.  If anyone knows how to fix this,
  306. please let me know.
  307.  
  308. There may also be an intermittent enforcer hit in there somewhere.  I
  309. thought I had fixed it, but it's happened since then and I haven't
  310. tracked it down yet.  It's very rare, and happens occasionally when
  311. closing another window.  It's only a read hit in page 0, so it's
  312. pretty harmless.  It's certainly never crashed my machine or anything.
  313. Still, if you run enforcer and see the hit, please save it and email
  314. it to me.  Thanks.
  315.  
  316. As I mentioned above, I'd like to support internationalization using
  317. locale.library.  As soon as I get the include files, I'll do this.
  318. Shouldn't be hard.
  319.  
  320. I'd like to let users specify their own font.
  321.  
  322. I'd like the clock to do public screen hopping for users of OS>=2.0,
  323. keeping the clock on the frontmost public screen.  What I plan is to
  324. let users specify a list of screens they wish to allow the clock onto,
  325. and if one of these is frontmost, the clock would move there.
  326.  
  327.  
  328.  
  329. AUTHOR
  330.  
  331. I welcome bug reports, suggestions, and comments.  I can be contacted
  332. by email at:
  333.  
  334.     pets@cs.mu.OZ.AU
  335.  
  336. or by physical mail at
  337.  
  338.     Peter Schachte
  339.     293 Edward Street
  340.     Brunswick East, Victoria  3057
  341.     Australia
  342.